package com.xxx.server.controller;

/*
* 登录
* */
import com.xxx.server.pojo.Admin;
import com.xxx.server.service.IAdminService;

import com.xxx.server.pojo.AdminLoginParam;
import com.xxx.server.pojo.RespBean;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;
import java.security.Principal;


@Api(tags = "LoginController")
@RestController  //相当于@Controller+@ResponseBody两个注解的结合
public class LoginController {

    @Autowired
    private IAdminService adminService;


    @ApiOperation(value = "登录之后返回token")
    @PostMapping("/login")

    public RespBean login (@RequestBody AdminLoginParam adminLoginParam, HttpServletRequest request){
        return adminService.login(adminLoginParam.getUsername(), adminLoginParam.getPassword(), adminLoginParam.getCode(), request);

    }

    //获取当前登录用户的信息
    @ApiOperation("获取当前登录用户的信息")
    @GetMapping("/admin/info")
    public Admin getAdminInfo(Principal principal){
        if (principal == null ){
            return  null;

        }
        String username = principal.getName();
       Admin admin= adminService.getAdminByUserName(username);
       admin.setPassword(null);
       admin.setRoles(adminService.getRoles(admin.getId()));
       return admin;
    }




    @ApiOperation(value = "退出登录")
    @PostMapping("/logout")
    public RespBean logout(){
        return RespBean.success("注销成功");
    }


}
